聚类算法——python实现层次聚类(AGNES)

算法思想

层次聚类是在不同层次上对数据进行划分,从而形成树状的聚类结构。
AGNES算法是自底向上的层次聚类算法。开始时将数据集中的每个样本初始化为一个簇,然后找到距离最近的两个簇,将他们合并,不断重复这个过程,直达到到预设的聚类数目为止。
计算距离的三个公式:
这里写图片描述
这里写图片描述
这里写图片描述
AGNES算法根据上面个三个不同的公式,相应的被称为均链接,单链接和全链接。
算法步骤如下:

  1. 将数据集中的每个样本初始化为一个簇,并放入集合C中。计算任意两个集合之间的距离,并存到M中。
  2. 设置当前聚类数目q = m。
  3. 当q大于k时执行如下步骤:
    3.1找到距离最近的两个集合Ci和Cj, 将Ci和Cj合并。并赋值给Ci。
    3.2在集合C中将Cj删除,更新Cj+1到Cq的下标。
    3.3删除M的第j行和第j列。更新M的第i行和第i列。
    3.4q = q-1
  4. 返回聚类集合C

python实现算法

 #-*- coding:utf-8 -*-

import math
import pylab as pl

#数据集:每三个是一组分别是西瓜的编号,密度,含糖量
data = """
1,0.697,0.46,2,0.774,0.376,3,0.634,0.264,4,0.608,0.318,5,0.556,0.215,
6,0.403,0.237,7,0.481,0.149,8,0.437,0.211,9,0.666,0.091,10,0.243,0.267,
11,0.245,0.057,12,0.343,0.099,13,0.639,0.161,14,0.657,0.198,15,0.36,0.37,
16,0.593,0.042,17,0.719,0.103,18,0.359,0.188,19,0.339,0.241,20,0.282,0.257,
21,0.748,0.232,22,0.714,0.346,23,0.483,0.312,24,0.478,0.437,25,0.525,0.369,
26,0.751,0.489,27,0.532,0.472,28,0.473,0.376,29,0.725,0.445,30,0.446,0.459"""

#数据处理 dataset是30个样本(密度,含糖量)的列表
a = data.split(',')
dataset = [(float(a[i]), float(a[i+1])) for i in range(1, len(a)-1, 3)]



#计算欧几里得距离,a,b分别为两个元组
def dist(a, b):
    return math.sqrt(math.pow(a[0]-b[0], 2)+math.pow(a[1]-b[1], 2))

#dist_min
def dist_min(Ci, Cj):
    return min(dist(i, j) for i in Ci for j in Cj)
#dist_max
def dist_max(Ci, Cj):
    return max(dist(i, j) for i in Ci for j in Cj)
#dist_avg
def dist_avg(Ci, Cj):
    return sum(dist(i, j) for i in Ci for j in Cj)/(len(Ci)*len(Cj))

#找到距离最小的下标
def find_Min(M):
    min = 1000
    x = 0; y = 0
    for i in range(len(M)):
        for j in range(len(M[i])):
            if i != j and M[i][j] < min:
                min = M[i][j];x = i; y = j
    return (x, y, min)

#算法模型:
def AGNES(dataset, dist, k):
    #初始化C和M
    C = [];M = []
    for i in dataset:
        Ci = []
        Ci.append(i)
        C.append(Ci)
    for i in C:
        Mi = []
        for j in C:
            Mi.append(dist(i, j))
        M.append(Mi)
    q = len(dataset)
    #合并更新
    while q > k:
        x, y, min = find_Min(M)
        C[x].extend(C[y])
        C.remove(C[y])
        M = []
        for i in C:
            Mi = []
            for j in C:
                Mi.append(dist(i, j))
            M.append(Mi)
        q -= 1
    return C
#画图
def draw(C):
    colValue = ['r', 'y', 'g', 'b', 'c', 'k', 'm']
    for i in range(len(C)):
        coo_X = []    #x坐标列表
        coo_Y = []    #y坐标列表
        for j in range(len(C[i])):
            coo_X.append(C[i][j][0])
            coo_Y.append(C[i][j][1])
        pl.scatter(coo_X, coo_Y, marker='x', color=colValue[i%len(colValue)], label=i)

    pl.legend(loc='upper right')
    pl.show()

C = AGNES(dataset, dist_avg, 3)
draw(C)



这是采用dist_avg函数运行的结果图。
这里写图片描述
这里写图片描述

  • 25
    点赞
  • 205
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
AGNESAgglomerative Nesting)层次聚类算法是一种自底向上的聚类算法。它首先将每个样本点看作是一个初始的独立聚类,然后通过计算样本点之间的距离(例如欧式距离)来合并距离最近的聚类,直到满足某个终止条件为止。 下面是一个Python实现AGNES层次聚类算法的代码示例: ``` import numpy as np def compute_distance(point1, point2): # 计算两个样本点之间的欧式距离 return np.sqrt(np.sum((point1 - point2)**2)) def agnes(data): # 初始化每个样本点为一个聚类 clusters = [[point] for point in data] while len(clusters) > 1: # 计算每两个聚类之间的距离,并找到最小距离及对应的两个聚类索引 min_distance = float('inf') min_index = (0, 0) for i in range(len(clusters)): for j in range(i+1, len(clusters)): distance = compute_distance(clusters[i], clusters[j]) if distance < min_distance: min_distance = distance min_index = (i, j) # 合并最近的两个聚类 cluster1, cluster2 = clusters[min_index[0]], clusters[min_index[1]] merged_cluster = cluster1 + cluster2 clusters.remove(cluster1) clusters.remove(cluster2) clusters.append(merged_cluster) return clusters[0] # 测试代码 data = np.array([[1, 2], [3, 4], [5, 6]]) result = agnes(data) print(result) ``` 上述代码首先定义了计算两个样本点之间欧式距离的函数`compute_distance`。然后,`agnes`函数以传入的数据`data`初始化每个样本点为一个聚类。在循环中,它计算每两个聚类之间的距离,并找到最小距离及对应的两个聚类索引。然后,它合并最近的两个聚类,将合并后的聚类添加到聚类列表中,并移除原来的两个聚类。最后,返回合并后的聚类列表中的唯一聚类。 以上代码是一个简单的AGNES层次聚类算法实现示例,可以根据实际需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值